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(57) Abstract: A scrambling code generating apparatus of a down- 
link transmitter in a UMTS mobile communication system, which 
uses one primary scrambling code for separation of base stations and 
multiple secondary scrambling codes for diarmel separation. The 
q)paratus includes a first m-seqoence generator for generating a first 
m-sequence and a second m-sequence generator for generating a sec- 
ond m-sequeoce. A first summer adds the first and second co-se- 
quences to generate the primary scrambling code. Aplurality of first 
masking sections each shift the first m-sequeoce, ami a plurality of 
second masking sections corresponding to the respective first mask- 
ing sections each shifts the second m-sequoice. A plurality of second 
surmners each adds one of the first shifted m-sequences with the sec- 
ond m-sequence corresponding to the first m-sequence. The ouq}ut 
of the second summers thus generates the multiple secondary scram- 
bling codes. 
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WO01A)5079 PCr/KROQAMTTaS 

APPARATUS AND METHOD FOR GENERATING SCRAMBLING CODE IN 
UMTS MOBILE COMMUNICATION SYSTEM 



BACKGROUND OF THE HJVENTION 

1. Field of the Invention 

The present invention relates generally to an apparatus and method for 
generating scrambling codes in a mobile communication system, and more particularly, 
to an s^aratus and method for generating a plural scrambling code using masking codes. 

2. Description of the Related Art 

A code division multiple access mobile communication system (hereinafter, 
referred to as "CDMA system'*) uses scrambling codes for the purpose of separating base 
stations. The European W-CDMA system, UMTS (Universal Mobile 
Telecommunication System) generates multiple scrambling codes classified into a plural 
scrambling code groiq) of a predetennined length. As a method for increasing edacity in 
addition to separation of base stations, which is the objective of using the scrambling 
codes in the CDMA system, orthogonal codes for multiple scrambling code groups are 
used to separate channels. That is, ^en all orthogonal codes for channel separation are 
used up for a scrambling code group, the mobUe communication system may utiUze a 
second scrambling code group to increase the number of available communication links. 
The UMTS mobile communication system uses a gold sequence with a length of 2"-l as 
scrambling codes in order to have multiple scrambling codes(one primary scrambling 
code and multiple secondry scrambling code in one base station)con5titated by multiple 
scrambling code groups. The gold sequence with a length of 2'®-l includes a group of 
2"-l distinct gold codes. The gold sequences of the same group have a good correlation 
diaracteristic with one another. Here, the gold sequence with a length of 2'*-l is divided 
into 3 S400 chips and repeatedly used for sorambling. 

Each base Nation in the UMTS mobile communication systems has a unique 
scrambling code called '^primary scrambling code" that is used to allow tenninals to - — -ik^--^ .- .-^j^ ^ 
differentiate each base. station fiom other base stations in the system. Also the each 
unique scrambling code used for ^yreading (scrambling) downlink chaimel signals of 
each base stations is referred to as '^primary scrambling code", and one of the scrambling 
code group used for spreading downlink data channels in case that an orthogonal codes 
is not available using the primary scrambling code is called "secondary scrambling 
code". The base station uses its unique primary scrambling codes for 
q>reading(s(7ambling) common control channel signals transmitted to all mobile stations 
with correq[>onding orthogonal code, for spreading(scrambling) data diaimel signals 
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transmitted to currently communicatnig mobae stations with coiresponding orthogonal 
codes which are assigned to each of the data chaimel signals for downlink channel 
separation. The base station has its unique primary scrambling codes in order for a 
mobile station to discriminate the base station from adjacent ones. Namely, the number 
of the primary scrambling codes used must be large enough, e.g., 512 lest that the mobile 
station should concurrently detect signals of base stations sharing the same primary 
scrambling codes. Thus the individual adjacent base stations use distinct primary 
scrambling codes among the 512 primary scrambling codes. When there exists no more 
orthogonal code with a primary scrambling code to be allocated for channel separation, 
the individual base station uses secondary scrambling code selected from its multiple 
secondary scrambling code groiq>s corresponding to the primary scrambling codes used. 

An exemplary unit using the multiple scrambling codes is a downlink in the 
UMTS system. It should be noted that for the purpose of illustration, the term 
"scrambhng code" is interchangeable with the term "gold code" or "gold sequence" 
indicating the same code as the scrambling code. 

Fig. 1 is a schematic diagram showing the structure of a dowidink transmitter in 
the UMTS mobile communication system. 

Referring to Fig. 1, upon receiving a dedicated physical control channel 
DPCCH and dedicated physical data chaimels DPDCHl, and DPDCH^^, which are 
previously channel-coded and interleaved, demultiplexers 100-104 (corresponding in 
number to the number of physical data charmels N plus one for the DPCCH) divide the 
dedicated physical control channel DPCCH and the dedicated physical data channels 
DPDCHl, ...» and DPDCHN into I (In-phase) and Q (Quadrature) channels. The I and Q 
diannels separately output from the demultiplexer 101 are fed into multiplieis 110 and 
111, respectively. The muhipUears 110 and 111 multiply the I and Q channels by an 
orthogonal code 1 for chaimel sq>aration, respectively, and send flie output to a 
scrambler 120. Similarly, fte I and Q channels separately output from the demultiplexers 
102 Enough 104 are subjected to the same operation as described above and fed into N 
scramblers 124.flirough 128, respectively. Then, a scrambhng code group generator 100 
generates secondary scrambling codes corresponding to the scramblers 120, 124 through 
128 and outputs them to die corresponding scramblers. Here, the scramblers 120, 124 
throi^"128 multq)ly flie output signals of the corresponding multipliers by the output 
signals of the scrambling code group generator 100 in a complex mode, to output the real 
parts of the soambled signals to a summCT 130 and the imaginary parts of the scrambled 
signals to a summer 135. The summer 130 sums up the real parts of the scrambled 
signals from the scrambles 120, 124 tinough 128, while the summer 135 sumps up the 
imaginary parts. 

Fig. 2 is a schonatic block diagram of the scrambling code groiq> generator 100 
shown in Fig. 1, wiudi concurrently genoates multiple scrambling code groups . 
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Although it is the fact that only primaiy scrambling codes are to be used for common 
control channels and data channels, secondary scrambling codes may be used in place of 
the primary scrambling codes to increase the number of available communication links. 
For example, if base station A uses primary scrambling code B with available orthogonal 
S codes C-H and all of the orthogonal codes C-H have been assigned to varioiis channels, 
there are no more available orthogonal codes that can be assigned to new channels if a 
new tenninal wants to conununicate with base station A. In that case, instead of using 
primary scrambling code A, secondary scrambling code Z can be used in place of 
primary scrambling code A for the new channels, and orthogonal codes C-H can then be 
10 assigned to the new chaimels because the new channels use secondary scrambling code Z 
mstead of primary scrambling code A. Thus, the new chaimels can be differentiated 
fiom the original channels that used the ortiiogonal codes C-H because the new channels 
use secondary scrambling code Z instead of primary code A. Thus the base station has 
to be c£9>able of generating multiple scrambling code groups. 

15 Referring to Fig. 2, the normal scrambling code group generator 100 includes a 

plurality of gold sequence generators 201 and a plurality of delays 203 corresponding to 
the gold sequence generators 201. Upon receiving control information about the 
scrambling codes for multiple channels fipom an upper layer, the gold sequence 
generators 201 generate scrambling codes, i.e., gold sequence codes based on the control 

20 information and output the generated scrambling codes to have an I-channel component. 

The delays 203 delay the scrambling codes with the I-chanmel component for a 
predetermined number of chips and generate delayed scrambling codes having a Q- 
chaimel component. 

Fig. 3 is a schematic diagram showing the structure of a downhnk receiver in 
25 the UMTS mobile communication system . For downlink common control channels, the 
receiver has to desraamble flie downUnk common control signals \^ch have been 
scrambled with the primary scrambling codes. Simultaneously, for downlink data 
chaimels, the receiver also has to descramble the signal scrambled with the secondary 
scrambling code when the downlink data channel uses secondary scrambling code. Thus 
30 the receiver must have a capacity of generating multiple scrambling codes. 

Referring to Fig. 3, upon receiving signals from the transmitter as shown in Figs. 
Y md 2, the i- aii Q-dMimei compisf^a^is of the received signals are*' fed mfi>" 
descramblers 310 and 315, respectively. A scrambling code group generator 300 
concurrently generates scrambling codes corresponding to the respective channels and 
35 outputs them to the desCTamblers 310 and 315. Then, the descramblers 310 and 315 
multiply the receives signals I+jQ by the conjugates of the scrambling codes received 
from the scrambling code groiq> generator 300 to descramble the received signals, and 
then ou^ut the I- and Q-chaimel components of the d^crambled signals to 
corresponding multq[>liars 320, 322, 324 and 326. Here, orthogonal codes assigned to the 
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respective channels are despread at tiie multipliers 320, 322, 324 and 326 and output to 
coiresponding demultiplexers 330 and 350. The demultiplexers 330 and 350 demultiplex 
the despread I- and Q-chamiel components, respectively . 

Fig. 4 is a schematic block diagram of the scrambling code group generator 300 
5 shown in Fig. 3, which concurrently generates multiple scrambling code groups . 
Although flie scrambling code group generator 300 is to use primary scrambling codes 
for common control channels in fact, it can also use secondary scrambling codes for 
channels used depending on the users, such as data chaimels, in case of a lack of 
available or&ogonal codes. Thus the mobile station has to be enable of generating 
1 0 multiple scrambling code groi4>s. 

Referring to Fig. 4, the scrambling code group generator 300 of the receiver 
includes a plxffality of gold sequence generators 401 and a pluraUty of delays 403 
corresponding to the gold sequence generators 401. Upon receiving control information 
about the scrambling codes for multiple channels from an upper layer, the gold sequence 
15 generators 401 generate gold sequence codes corresponding to the control information 
and output the generated gold sequence codes to have an I-channel component. The 
delays 403 delay the gold sequence codes with the I-channel con^nent for a 
predetermined number of chips to generate the gold sequence codes of a Q-chaimel 
component 

20 Fig. 5 is a schematic diagram illustrating the structure of the gold sequence 

generators shown in Figs. 2 and 4 . 

Referring to Fig. 5, a gold sequence is normally generated through binary 
adding of two distinct m-sequcnces. A shift register that generates fte iqipcr m-sequence 
is implemented wiA a generator polynomial defined as f(x) = + x^ +1 , and a shift 
25 register generating the lower m-sequence is implemented with a generator polynomial 
definedas f(x) = x" +x'° + x' +x^ +1. 

In the present UMTS standard specification, there is no description for 
saambHng code numbering and its genoation. Th^efore, in the Hght of the UMTS 

standard q)ecificalion the recdvex and the transniitter require noany scrambling 
30 code generators described above to generate multq>le scrambling codes and flms uses 
distinct gaierators for the individual scrambhng codes, which leads to an increase in the 
hardware complexity. Furthermore, when using gold sequences as the scrambling codes, 
the hardware complexity may be dq)endent on the way the scrambling codes are divided 
into primary and secondary scrambling codes and dependent on how the scrambling 
35 codes are numbered. 



SUMMARY OF THE INVENTION 
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It is, therefore, an object of the present invention to provide an apparatus and 
method for generating scrambling codes grouped in units of a predetennined length 
using mask functions, thereby minimizing hardware complexity. 

It is another object of the present invention to provide an ^paratus and method 
5 for generating scrambling codes including a primary scrambling code and associated 
secondary scrambling codes to be used in place of the primary scrambling code to 
increase the number of available communication links. The scrambling codes are 
generated by using mask functionsJt is further another object of the present invention to 
provide an ^aratus and method generating a primary scrambling code and associated 

10 secondary scrambling codes. In an embodiment of the present invention, a first diifl 
register is used to generate a first m sequence and a second shift register is used to 
generate a second m sequence. The first m sequence is added with the second m 
sequence to generate a primary scrambling code. To generate the associated second 
scrambhng codes, the bits of the first shift register are entered into N m as k i n g sections 

15 which use masking functions to cychcally shift the fiirst m sequence. The outputs of 
each of the masking sections are added with the second m sequence to generate N 
secondary scrambling codes. It is further another object of the present invention 

to provide an scrambling codes numbering scheme for simple generation of the 
scrambling codes by one scrambling code goierator. 

20 

To achieve the above objects of the present invention, there is provided a 
method for generating one primary scrambling code assigned to a base station and 
multiple secondary scrambling codes with two m-sequence generators each having 
phirahty of concatenated shift registers, tiie method including the steps of: goierating a 

25 first m-sequcncd>y first m-sequence generator having a given genoafion polynomialand 
a second m-sequence by second m-sequence generator having a given generation 
polynomial different fiom the first m-sequence generation polynomial; adding the ou^ut 
of the first m-sequence generator and the ou^ut of the second m-sequence generator to 
generate first primary Scrambling code for generating primary scrambling code; 

30 receiving all values of a first m-sequence registers; multiplying the first m-sequeace 
register values with a mask vahie winch is detennining secondary scrambling code and 
simrming ffie muhipUed vahies at evcxy clock signal; and generating i'th secondary 
scrambling code by addSng the summed value and second m-sequence generator's output 

35 In another aspect of the present mvention, there is provided an ^jparatus for 

generating multiple scrambbng codes in a CDMA mobile communication system, which 
gaiCTates one primary scrambKng code assigned to a base station and multiple secondary 
scrambbng codes, the apparatus including: a first m-sequence generator having phnality 
of serial concatenated shift register for genwating a first m-sequeace; a second m- 
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sequoice generator having plurality of serial concataiated shift register for generating a 
second m-sequence; a first summer for adding the first and second m-sequeaces to 
generate the primary SCTambling code; at least a masking sections for receiving each of 
the first m-sequence generator's register values (aj, multiplying the register values and 
mask values (kj) which is determining secondary scrambling code by shifting the first m- 
sequence and summing the mutiphed vahies(ai x kj); adding the second m-sequence with 
the summed values to generate the secondary scrambling code. In fiirther another aspect 
of the present invention, there is provided a scrambling code generating ^aratus of a 
downlink transmitter in a UMTS mobile communication system, which uses one primary 
scrambling code for separation of base stations and multiple secondary scrambling codes 
for channel separation, the apparatus including: a first m-sequence generator for 
generating a first m-sequence; a second m-sequence generator for generating a second 
m-sequence; a first summer for adding the first and second m-sequences to generate the 
primary scrambling code; a plurality of masking sections, each of the first masking 
sections for shifting the first m-sequmce; ; and a plurahty of second summers, each of 
the second summers for adding one of the shifted first m-sequences with the second m- 
sequence, the output of the second summers generating the multiple secondary 
scrambling codes. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The above and othCT objects, features and advantages of the present invention 
will become more parent fi^m the following detailed description when taken in 
conjunction with the accompanying drawings in which: 

Fig. 1 is a schematic diagram showing the structure of a known downlink 
transmitter in a gmaraJ UMTS mobile communication system; 

Fig. 2 is a schanatic block diagram of a known scrambling code groiq> 
generator stown in Fig. 1; 

Fig. 3 is a schematic block diagram showing the structure of a known downlink 
receiver in the general UMTS mobile communication system; 

Fig. 4 is a schematic blodc diagram of a known scrambling code group 

generator shown in Fig. 3; 

Fig. 5 is a dialled diagram showing the structure of a known scrambling gold 
groiq) generatorin the general.UMTS mobile communication system; ^ ^ ^ , . 

Fig. 6 is a diagram showing the structure of a scrambling code in accordance 
with a first embodiment of the presoit invention; 

Fig. 7 is a detailed diagram showing the structure of a scrambling code group 
generator of a downhnk transmitter in a UMTS mobile communication system in 
accordance with the first embodiment of the present invention; 

Fig. 8 is a d^ailed diagram showing the structure of a scrambling code group 
gmaator of a downlink receiver in a UMTS mobile conununication system in 
accordance witti the first embodiment of the present invention; 
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Fig. 9 is a diagram showing the structure of a scrambUng code in accordance 
with a second embodiment of the piesait invention; 

Fig. 10 is a detailed diagram showing the structure of a scrambling code group 
generator of a downlink transmitter in a UMTS mobile communication system in 
5 accordance with the second embodimoit of the present invention; and 

Fig. 1 1 is a detailed diagram showing the structure of a scrambling code group 
generator of a downlink receiver in a UMTS mobile communication system in 
accordance with the second embodiment of the present invention; 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

J 0 A preferred embodiment of the present invention will be described below with 

reference to the accompanying drawings. In the following description, well-known 
functions or constructions are not described in detail since they would obscure the 
invention in unnecessary detail. 

A gold code used herein as a scrambling code is generated through binary 
15 adding of two distinct m-sequences. Assuming that the two m-sequences each having a 
length L are defined as ml(t) and m2(t), respectively, a set of gold codes may comprise 
L distinct gold sequences with good correlation characteristic with one another. The set 
of gold codes can be expressed by Equation 1. 

[Equation 1] 

20 G = (m,(t + T) + m2(t)|0<T<L-l) where, t is a time variable number and x 

is shift value. As uridarstood fibiii Equation 1, the set of gold codes is a set of all 
sequences that comprises the sum of tiie m-sequence m,(t) cyclically shifted t times and 
the m-sequence m/t). Thus, for the purpose of the present invention, the sum of the m- 
sequence m,(t) cyclically shifted x time and the m-sequence m^ii) will be designated as a 

25 gold code g^ That is, g^(t) = m^(t'^i)^m^{t) . If the period of the gold code is 2'*-l, 
then the individual m-sequences constituting the gold code also have a period of 2*^-1. 
Thus the m-sequence m,(t) can be cyclically drifted a maximum of 2'*-l times and the 
numbCT of elements in the set of ftie gold codes is equal to 2"-l, ^ch is the maximum 
value of the cyclic shift. 

30 The set of gold codes used in the embodiments of the present invention has 2"- 

1 gold codes as elements each of which comprises an m-sequence m,(t) having a 
generator polynomial defined as f(x) = x'* + +1 and an m-sequence nijC) with a 
generator polynomial defined as f (x) = x" + x'° + x^ + x^ + 1 . 

A second m-sequence m,(t) cycHcally shifted x times can be obtained by 
35 qTplying mask fimctions to the monory values of a shift register generating the original 
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m-sequence. 

The embodiments of the present invention provide a generator for conciirrently 
generating multiple gold sequences using the mask functions, and a method for 
efficiently dividing the set of gold sequences into a primary scrambling code set and a 
secondary scrambling code set to reduce the number of mask fimctions stored in the 
memory. 

First Embodiment 

Fig. 6 is a diagram showing the stoicture of primary and secondary scrambling 
codes in accordance with a first embodiment of the present invention. 

First, when a gold sequence is selected &om 2**-l length gold sequences, the 
first 38400 chips are used as a primary scrambling code, the second 38400 chips a first 
secondary scrambling code corresponding to the primary scrambling code, the third 
38400 chips a second secondary scrambling code corresponding to the primary 
scrambling code, the fourth 38400 chips a third secondary scrambling code 
corresponding the primary scrambling code, the fifth 38400 chips a fourth secondary 
scrambling code corresponding to tiie primary scrambling code, the sixth 38400 chips a 
fifth secondary scrambling code corresponding to the primary scrambling code. Here, 
when 512 primary scrambling codes are used, there are five groups of secondary 
scrambling codes corresponding to the 512 primary scrambling codes. Specifically, 2'*-l 
(the Iragth of scrambling codes) divided by 38400 is equal to six (scrambling code 
groups). Out of six scrambling code groiips, the first scrambling code group is used as 
primary scrambling codes and the remaining five scrambling code groups sre used as 
secondary scrambling codes, in this structure, if a cell(base station) uses its own primary 
scrambling code and secondary scrambling codes selected out of its own secondary 
scrambling codes group , then the selected secondary scrambling codes belonging to the 
secondary scrambling code groiq) corresponding to the primary scrambling code will be 
used for downlink cbaimel scrambling codes when orthogonal codes are not available 
with the primary scrambling code. As ^own in Fig. 6, once a primary scrambling code 
is selected, the* secondary scrambling codes corresponding to the primary scrambling 
code are also part of a gold code also includes the primary scrambling code.. Here, 
"'"the* secondary scrambling codes are generated through q>plication of mask fimctions to ' 
the primary scrambling codes. This method is adapted to a scrambling code group 
generator of a transmitter as illustrated in Fig. 7, which concurrently generates one 
primary scrambling code and midtiple secondary scrambling codes. 

Referring to Fig. 7 , the scrambling code group generator 701 comprises a first 
m-sequence gaierator 750 including: an iqiper shift register memory (hereinafter, 
referred to as "first shift register memory*') 700(with registers 0 to 17) and an addCT 730, 
a second m-sequence generator 760 including; a lower shift register memory (h^einafter. 
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refared to as "second shift register memoT/*) 705 (with registers 0 to 17) and an adder 
735, a pluraKty of masking sections 710 to 712, 714 to 716, a plurality of adders 742 to 
744 and 740, and a phirality of delays 722 to 724 and 720. The first shift register 
memory 700 stores a predeteraiined register initial value "a^" and the second shift 
register memoiy 705 stores a predetenoMned register initial value The values 

stored in each of the registers in the memory 700 and the memory 705 may change 
during every period of an input clock (not shown). The register memory 700 and 705 
store 18 bit (or symbol) binary values and "b", respectively (i = 0 to c-1 where c = 
the total number of registers in the register memories 700 and 705). 

The first m-sequence generator 750 generates a first nv-sequece using the register 
memory 700 and the adder 730 which is a binary adder that adds the binary values fi^m 
the registers 0 and 7 of the register memory 700 and outputs the sum into the register 
17. The register 0 of the register memory 700 sequentially ou^uts binary values that 
form the first m-sequence during every period oftheiiq)ut clock. The masking 
sections 710 to 712 store mask code values(k"i to k^i ) for generating cyclical shifts of the 
first m-sequence by a predetermined number of chips.. The cyclical shifts are achieved 
by multiplying the mask code values by the register value "a^" of the first shift register 
memory 700, as expressed by the following equation: ^(A:^/ xa^) (L = 1 to N). The 
resulting values are provided to the adders 742 to 744, respectively. 

The second m-sequence generator 760 generates a second m-sequence using 
the register memoiy 705 and the adder 735 winch is binary adder that adds the binary 
values fiom the registers 0, 5, 7 and 10 of the register memory 705 and ou^uts the sum 
into the register 17. The regiistCT O of the register m^^ sequentially outputs 

binary values that form the second m-sequence duringeveryperiodoftiieiiq)ut clock. 
The masking sections 714 to 716 store each mask code values (sVto ) fiwr generating 
cyclical shifts of the second m-sequence by a predetermined number of chips. The 
cyclical shifts are achieved by multiplying the mask code values by the register value 
"b;** of the second shift register memory 705. The resulting values are provided to the 
adders 742 to 744, respectively. Each of the m-sequence generators 750 and 760 
generates an m-'sequence according to the corresponding generator polynomial. 

^ . , - - . The adder 740. adds. the 0*th registCT .values(i.e., the last bits) of the first^aaid,, 
second shift register memories 700 and 705 to generate a scrambhng code, which 
becomes the primary scrambling code. The adders 742 to 744 add one bit generated fipom 
each of the masking sections 710 to 712 connected to the first shift register memory 700 
to one bit generated fiom the masking sections 7 1 4 to 7 1 6 corresponding to the masking 
sections 710 to 712, respectively. In other words, the output bom the first masking 
section 710 fiom the first group is added with the output fixmi the first maskmg section 
714 from ttxe second group and so on, until the ou^ut fipom the Nth masking section 712 
from tiie first group is added with the ou^ut fiom the Nth niasking section 716 from 
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second group. Thus, each of the masking sections 710 - 712 in the first gpoxtp has a 
coiresponding masking section in the masking sections 714 - 716 of the second group. 
The outputs from the corresponding masking sections are added together in the adders 
742 - 744, respectively. That is, the individual masking sections have a conjugate on a 
one-to-one basis with respect to the first and second shift register memories 700 and 705. 
For example, the first masking section 710 of the first shift register memory 700 
corresponds to the first masking section 714 of the second shift re^er memory 705, the 
N*th masking section 712 corresponding to the N'th masking section 716, and so on. 
Between the two conjugate masking sections (i.e., first masking sections 710 and 714, or 
N'th masking sections 712 and 716) is connected the adder 742 to 744 that add the two 
bits output fiom the masking sections in reqjonse to the input clock. Here, the output 
signals of the summers 742 to 744 hacve an I-channel component. 

The delay 722 to 724 and 720 delay the I-chamiel signals for a predetermined 
number of chips to generate respective Q-channel signals. 

Now, a description will be given to an operation of the present invention as 
constructed above. 

Once an initial vahie for the primary scrambling code is qjplied to the first and 
second shift register memories 700 and 705 each having 18 registers for cyclicaUy 
shifting the register value X' or 'V, the O'th register values of the first and second shift 
register memories 700 and 705 are fed into the adder 740 and the 18 register values 'V 
of the first shift register memory 700 are fed into the first to N'th masking sections 710 
to 712 in order to generate cyclically shifted sequences of the first shift registers. 
Meanwhile, the 18 register values "bj" of the second shift register memory 705 are fed 
into tiie first to N'th masking sections 714 to 716 in order to generate t^lically shifted 
sequences of the first diift registers. Then, the first masking section 710 masks the input 
values fiom the first (upper) shift register memory 700 (all 18 bits firom 18 registers in 
the shift register memory 700) with a mask fimction k'; (i.e., ^^(k'i x a,) ) and outputs 
the masked vahies to Ae summer 744 for generating the first secondary scrambling code. 
The masking is concuiTently processing in every masking sections 710 - 712. The N'th 
masking section 712 masks the input values firan the first (upper) shift registers with a 
. mask fimction ^(k^^^h)) PV^^^ .*? "^^^ed to the simmCT 742 

for generating the N'th secondary scrambling code . The N'th masking section 716 
masks the input vahies from the second (lower) shift registers with a mask fimction s"; 
(i.e., ^{s^i X a;)) and ou^uts the masked values to the summer 744 for goierating the 
N'th secondary sraambling code. The first masking section 714 masks the input values 
from the register memory 705 with a mask fimction s\ (i.e., ^^(s'i xaj)) and outputs 
the resulting values to the adder 742 for generating the first secondary scrambling code. 
Each of the masking sections 710 - 712 masks the input vahies firan Ae first shift 
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register memory 700 and outputs the masked value to the respective adders 742 - 744. . 
Then, the adder 740 adds the output bits from the O'th registers of the first and second 
shift register memories 700 and 705. These generated output signals are immediately 
delayed at the delay 720. The adder 744 adds the ou^ut bits from the N*th masking 
5 sections 712 and 716 to generate I-channel signals, which are immediately fed into the 
dehiy 724. The delay 722 delays the I-channel signals output from the adder 744 for a 
predetermined number of chips to goierate Q-channel scrambling signals. The adder 742 
adds the output bits from the first masking sections 710 and 714 to generate I-channel 
signals. These I-channel signals are inmiediately delayed for a predetermined number of 

10 chips at the delay 722. Then, the O'th and seventh register values of the first shift register 
memory 700 are added at the summer 730 and the added value is iiq)utted to the 
seventeenth register, as the left-sided values are shifted to the right side by one and the 
utmost left-sided register is newly filled with the output value of the summer 730. The 
0*th, fifth, seventh, and tenth register values of the second shift register memory 705 are 

15 added at the adder 735, the added value is iiq)Utted into the seventeenth register, as the 
left-sided values are shifted to the right side by one and the utmost left-sided register 
(i.e., the seventeenth register) with the output value of the summer 735. This procedure 
is repeated to generate multiple scrambling codes. 

Fig. 8 is a diagram showing a scrambling code generator of a receiver for 
20 concurrently generating one primary scrambling code and one secondary scrambling 
code. The receiver has only to use scrambling codes for a common control channel and a 
data channel assigned thereto and thus needs one primary scrambling code and one 
secondary scrambling code. 

Refening to Fig. 8, once an initial value for the primary scrambling code is 
25 a^jpli^ to ^ register memory 840 having 18 upper shift r^iisters and a second 

shift register memory 845 with 18 lower shifter register, the 0*fti legists vahies of Ae 
first and second shift r^^ster memories 840 and 845 are fed into an adder 810. The 
output of the adder 810 is a primary scrambling code. The 18 register values "a^" of the 
first shift register memory 840 are fed into a masking section 820. Meanwhile, the 18 
30 register values ."hj** of tfcie second shift register memory 845 are fed into a masking 
section 825. Then, the masking section 820 masks the iiqput values firom the first shift 
regLsto with_a ma^ function k; O-e.. ^ I? 3. 

adder 815 for generating the first secondary scrambhng code. The masking section 825 
masks the input values from the second (lower) shift register with a mask fimction Sj (i.e., 
35 X^^i^^i^^ ™^ ou^uts the masked values to an summer 815 for generating the 
secondary scrambling code. Then, the adder 810 adds the output bits from the O'th 
registers of the first and second shift register memories 800 and 805 to generate I- 
charmel primary scrambling code signals. These I-channel primary scrambhng code 
signals are immediately delayed for a predetermined number of chips at a delay 830 to 
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generate Q-chaimel primary scrambling code signals. The adder 815 adds the output bits 
fiom the masking sections 820 and 825 to generate I-channel primary scrambling code 
signals, which are inmiediately delayed at a delay 835. Then, the O'thand seventh 
register values of the first shift registos are added at the adder 800, and the added value 
is output to the seventeenth register, as the left-sided values are shifted to the right side 
by one. The O'th, fifth, seventh and tenth register values of the second shift registers are 
added at the adder 805, and the added value is ou^ut to seventeenth register, as the left- 
sided values are shifted to the right side by one. This procedure is repeated to generate 
multiple scrambling codes. 

The scrambling code generator of the first embodiment needs plurality of 
distinct mask fimctions stored in the masking sections in order to generate each 
secondary scrambling code, i.e., it uses 2N mask fimctions to generate N scrambling 
codes. Accordingly, the structure of primary and secondary scrambling codes shown in 
Fig. 6 enables inq>lementation of the scrambling code generator of the transceiver 
structure shown in Figs. 7 or 8, which fiirther includes only 2N mask fimctions with a 
quite little hardware complexity to generate multiple scrambling codes. 

Second Embodiment 

Fig. 9 is a diagram showing the structure of primary and secondary scrambling 
codes in accordance with a second embodiment of the present invention. While the first 
embodiment masks both m-sequences mi(t) and xn^it) to generate scrambling codes, the 
second embodiment involves cyclic shift of the m-sequence mjO) only other than m,(l) 
to generate scrambling sequences. That is, this embodiment is well expressed by 
Equation 1. 

Referring to Fig. 9, \^en M secondary scrambling codes cotreqpond to one 
primary scrambling code, the first, (M+2)'th, (2M+3)'th, ((K-1)*M+K)'th , and 
(511M+512)'th gold codes are used as primary scrambling codes. The secondary 
scrambling codes corresponding to the (((K-1)*M+K)*th gold code used as the (K)'th 
primary scrambling code^are composed of M gold codes, i.e., ((K-1)*M+(K+1)), ((K- 
l)*M+(K+2))..'., and (K*M+K)'th gold codes. Here, with 512 primary scrambling 
codes used, each of the secondary scrambling code sets corresponding to tiie 512 
primary scrambling codes is. composed, of M secondary scrambling codes.. In ..this, 
structure, if a cell uses one of the primary scrambling codes then secondary scrambling 
codes belonging to the secondary scrambling code group corresponding to the primary 
scnimbling code wiU be usedwhen the secondry scrambling codes need to be used As 
shown in Fig. 9, once a primary scrambling code is selected , the secondary scrambling 
codes correspcmding to the primary scrambling code are generated by the adding 
cyclically shifted first m-sequences and the second m-sequence. Here, the secondary 
scrambling codes are generated through s^lication of mask functions to the sequences 
in the first shift register memory . This method is ad^ted to a scrambling code generator 
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of a transmitter as illustrated in Fig. 10, which concurrently generates one piimaiy 
scrambling code and multiple secondary scrambling codes . 

Referring to Fig. 10, the first m-sequence generator 1050 comprises a first shift 
register memory 1040( with registers 0 to 17) and an adder 1010 for adding the outputs 
of the registers 0 and 7. The second m-sequence generator 1060 comprises a second 
register memory 1045(with registers 0 to 17) and an adder 1015 for adding the outputs 
of the registers 0, 5, 7 and 10. The scrambling code generator shown in Fig. 10 
comprises the two m-sequence generators 1050 and 1060, a plurality of masking 
sections 1000 to 1005, a plurality of adda:s 1032 to 1034 and 1030, and a plurality of 
delays 1022 to 1024 and 1020. The first shift register memory 1040 stores a 
predetennined register initial value "ao" and the second shift register memory 1045 
stores a predetermined register initial value 'V*- The shift register memory 1040 and 
1045 can store 18 binary values (bits or symbols) 'V' and "b"(0 < i < 17 ). The two m- 
sequence genraators 1050 and 1060 generate respective serial output sequence bits 
according to each gaieration polynomials at every period of the input clock(not shown). 
The second embodiment of the present invention uses a gold code length of 38400 
symbols to generate scrambling codes. Thus, the shift register memories 1040 and 1045 
may be reset to the initial value when each of the register memories 1040 and 1045 
outputs a sequence having a length of 38400 symbols. 

The first m-sequmce generator 1050 gmerates the first m-sequence using the 
register memory 1040 and the adder 1010 v/inch is a binary adder that adds the binary 
values from the registers 0 and 7 of the register memory 1040 and outputs the sum mto 
the register 17. The register 0 of the registo: memory 1040 sequentially outputs binary 
vahies that form the first m-sequence during every period of the ii5)Ut clock. The 
maskmg sections 1 000 to 1 005 store mask code values (k"; to k^i) for generating cycKcal 
drifts of fte first m-sequoxce by a predetermined number of chips.. The cyclical shifts 
are achieved by multiplying the mask code values by the register value 'V' of the first 
shift register memory 1040, as expressed in the foUowing equation: ^ • 

resulting values are provided to the adders 1032 to 1034, respectively. In the preferred 
onbodimrals of the present invaation, each of the mask code values (k\ to k^^O creates a 
new sequence ^ch is a first m-sequrace cyclically shifted 1 to N times. Thus, each of 
theinask code values is detenmined by the desired number of ^ - ^ . 

The addCT 1030 adds the O'th registCT vahies of the first and second shift register 
memories 1040 and 1045 to generate a scrarnbhng code, which becomes a primary 
scrambling code. The adders 1032 to 1034 each adds one bit generated bom the 
masking sections 1000 to 1005 to one bit generated firom the second shift register 
memory 1045, respectively, to generate I-channel scrambhng code signals. Here, the 
output from ftie adder 1030 is used as the primary scrambhng code and the scrambling 
codes ou^ from the adders 1032 to 1034 can be used as secondary scrambKng codes 
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tiiat coiiesponds to the primary scrambling code. The following is an example of 
possible mask values (k', to k"i): k\ =(000000000000000010), k^j = 

(000000000000000100), k^i =(0000000000000001000) By controlling the mask 

values, other primary and secondary codes can be generated. The following example 
shows how to obtain a necessary mask code to cyclically shift a m-sequence 'n' times. 
In genraal, divide x" by the generation polynomial for the m-sequence (i.e., x" /f(x)) and 
take the remainder of the division to form the mask code. For example, if a mask code 
tbat cyclicaUy shifts 31 times is desired, take x*' and divide it by/(x) = ac" +x' +1 the 
generation polynomial and find the ronainder which cannot be divided further. The 
final remainder is x" + x' + x^ as shown by the following: 

^3. ^^.3yS ^y3(^7 +1)^ ^^3 ^^2^.8 +^3 ^^2(^7 + J) + ^ 3 ^^.3 ^^9 ^^2 

The binary sequence corresponding to x" + x' + x^ is 000010001000000100 
which is the mask code needed to cyclically shift the m-sequence 31 times. 



The delays 1022 to 1024 and 1020 delay the I-channel signals for a 
predetermined numbCT of chips to generate Q-channel scrambling code signals. 

As described above, the second embodiment of the present invention generate 
scrambling code groups shown in Fig. 9 and only uses one gold code generator, masking 
sections 1000 to 1005 and adders 1022 to 1034.. 

Now, a description will be pvra to an opeiratidn of the present invention as 
constructed above. 

Once an initial value for the primary scrambling code is applied to the first and 
second shift register memories 1040 and 1045 each having 18 registers, the O'th register 
vahies of tiie first and second shift register memories 1040 and 1045 are fed into the 
adder 1030 and flie 18 TCgfSta values "aj" of the first shift register memory 1040 are fed 
mto the first to N*th masking sections 1000 to 1005 in order to generate 1 to N cyclically 
shifted sequences of the first m-sequence. Thai, the first masking section 1000 masks 
.the input vahie(ai) from the fiTSt.(upper).shift,register m«moryJQ4^^^ ^.c^S?,. 
k', for generating the first secondary scrambling codes (i.e., ^(k'i xaj)) and ou^uts 
the masked vahie(ai) to the adder 1032. The N'th masking section 1005 masks tiie input 
vahie(ai) from the first (upper) shift register memory 1040 with a mask fimction k", for 
generating the N'th secondary scrambling codes (i.e., ^(k^i xaj)) and outputs the 
masked vahies to the adder 1034. At the same time, the adder 1030 sums the output bits 
from the 0*th registers of the first and second shift register memories 1040 and 1045. 
The generated ou^ut signals are inmiediately delayed at the delay 1022. The adder 1032 
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sums the output bits ftom the first masking section 1000 and the 0*th shift register of the 
second shift register memory 1045. The output signals are immediately fed into the 
delay 1022. Thereafter, the O'th and seventh register values of the shift register memory 
1040 are added at the adder 1010 and the adder 1010 outputs the sura to the seventeenth 
register, as the left-sided values are shifted to the right side by one and the utmost left- 
sided register is newly filled with the output vahie of the adder 1010. The O'th, fifth, 
seventh and tenth register values of the shift register memory 1045 are added at the 
adder 1015, and the adder inputs the sum into the seventeenth register of the register 
monory 1045 as the left-sided vahies are shifted to the right side by one to fiU the 
utmost left-sided register (i.e., the seventeenth register) with the output value of the 
adder 1015. This procedure is repeated to generate multiple scrambling codes. 

Fig. 1 1 is a diagram showing a scrambling code generator of a receiver for 
concurrently generating one primary scrambhng code and one secondary scrambhng 
code. The embodiments shown in Figs 10 and 1 1 can be used either in a transmitter or a 
receiver. 

The receiver according to the second embodiment of the present invention has 
only to use one secondary scrambhng code and thus needs only one masking section 
1100. 

Referring to Fig. 11, once an initial value for the primary scrambling code is 
applied to a first shift register memory 1140 having 18 registers and a second shift 
register memory 1 145 with 18 registers , the O'th register values of the first and second 
shift register memories 1 140 and 1 145 are fed into an adder 1 120. The 1 8 register values 
"a^" of the first diift register memory 1 140 are fed into the masking section 1 100 in order 
to gaicrate a cyclically shifted m-sequence. Then, the masking section 1100 masks the 
input vahiesCaJfiom the register memory 1140 with a mask vahies kg for generatmg the 
first secondary scrambhng codes (i.e., ^^(kj x a;)) and outputs the masked values to an 
adder 1125. The adder 1120 sums the output bits from the O'th registers of the first and 
second shift register memories 1140 and 1145. The output signals of the adder 1120 are 
fanmediately delayed at a delay 1130. Meanwhile, the adder 1125 sums the output bits 
fiom the masking section 1100 and the O'th shift register of the second shift register 
meamorx 1145 and outputs the sum to a delay 113^5 im^ Then, tiie 0*th arid 

sevrafli re^stCT vahies of the first s^ register mmory^ll4^^ added at the adder 
1110, in which case the left-sided values are shifted to the right side by one and the 
utmost left-sided register is newly filled with the output value of the summer 1 1 10. The 
O'th, fifth, seventh and tenth register vahies of the second shift register memory 1 145 are 
added at the addo- 1115, shifting the left-sided vahies to the right side by one and newly 
filhng the utmost left-sided register with the output value of the adder 1115. The mask 
vahies can be controlled by a controller(not shown) when the receiver needs to generate 
other scrambling codes. 
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The scrambling code generator of the second embodnnent needs mask values 
stored in the masking section in order to genraate the secondary scrambling code, i.e., it 
uses N mask vahies to generate N scrambling codes. Accordingly, the structure of 
primary and secondary scrambling codes shown in Fig. 9 enables implementation of the 
5 scrambling code generator of the transceiver structure shown in Figs. 10 and 11, which 
further includes only N mask functions with a quite little hardware complexity to 
generate multiple scrambling codes. 

While the invention has been shown and described with reference to a certain 
preferred embodiment thereof, it will be understood by those skilled in the art that 
10 various dianges in form and details may be made therein without departing ftom the 
spirit and scope of the invention as defined by the fended claims. 
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WHAT IS CLAIMED IS: 

L A method for generatmg a primary scrambling code and N secondary 
scrambling codes associated with the primary scrambling code for a mobile 
telecommunication syston, the method comprising the steps of: 

(a) generating a first m-sequence from a first shift register memory 
having a plurality of registers with values a^ (i = 0 to c-1 where c = the total 
number of the registers); 

(b) generating a second m-sequence from a second shift register 
memory having a plurality of registCTS with vahies b; (i = 0 to c-1 where c = the 
total number of the registers); 

(c) adding the first m-sequence with the second m-sequence to generate 

the primary scrambling code; 

(d) masking aj (i = 0 to c-1) to produce a L* secondary sequence which is a 
first m-sequence cyclically shifted L times, where 1 ^N; and 

(e) adding the L*** secondary sequence with the second m-sequence to 
produce a L* secondary scrambling code. 

2. The method of claim 1, wherein the first and second m-sequences are 
generated based on a first generator polynomial and a second generator polynomial, 
respectively. 

3. The method of claim 1, wherein the naasking in step (d) is expressed by 
the following equation: ^{^''i x a.) , 

4. The method of claim 2, fiirther comprising the step of cyclically 
shifting the first shift register memory. 

5. The m^iod of claim 4, wherein the step of cyclically shifting the first 
shift register memory comprises the steps of adding predetermmed bits of the first shift 
register memory based on the first gmerator polynomial of the first m-sequence, right 

-shifting Ae first shift- registor, manory and . msating, the_^^ 
predetermined bits into a^^^j. 

6. The method of claim 5, wherein aois added with a, to form a next a^j 

7. The method of claim 2, fiirther comprising the step of cyclically 
shifting the second ddft register memory. 

8. The method of claim 7, wherein the step of cyclically shifting the 
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second shift register memory comprises the steps of adding predetermined bits of the 
second shift register memory based on the second generator polynomial of the second m- 
sequence, right shifting the second shift register memory and inserting the value of the 
added predetermined bits into b^,. 

9. The method of claim 8, wherein bo is added with bj, b7, and b,o to form 
anextbj^,. 

10. The method of claim 1, finther comprising the step of delaying the L* 
secondary scrambling code to produce a Q-channel component of the secondary 
scrambling code, whwein the undelayed L* secondary scrambling code is a I-channel 
conqK}nent of the L*** secondary scrambling code. 

11. A method for generating a primary scrambling code and N secondary 
scrambling codes associated with the primary scrambling code for a mobile 
telecommunication system, the method comprising the steps of: 

(a) generating a first m-sequence from a first shift register memory 
having a plurality of registras with values a; (i = 0 to c-1 where c = the total 
numb^ of registers); 

(b) generating a second m-sequence firom a second shift register 
memory having a plurality of registers with values b; (i = 0 to c-1 where c = the 
total ninnber of registers); 

_ (c) adding the first m-sequaice with the second m-sequence to generate 

tb& primary scrambling code; 

(d) ii^iutting aj (i = 0 to c-1) into masking sections; 

(e) masidng aj (i = 0 to c-1) in each of the masking sections to produce 

secondary sequences; 

(f) adding each of the secondary sequences with the second m-sequence to 

produce flieN secondary scrambling codes, 

wherein a L* secondary sequaice is a first m-sequence cyclically shifted L 

times, whae 1 -^N. 

12. TTie method of claim 1 1, wherein the first and second m-sequences are 
gaiaated based on a first generator poljnniomiai and a second genCTatof polynomial, 
respectively. 

13. The method of claim 11, wherein the masking in step (e) is expressed 
by the following equation: J^C^Sxa,). 



14. The method of claim 12, finther comprisiiig the step of cyclically 
shifting the first drift register manory. 
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15. The mcEthod of claim 14, wherein the step of cycUcally shifting the first 
shift register memory comprises the steps of adding predetermined bits of the first shift 
register memory based on the first generator polynomial of the first m-sequence, right 

5 shifting the first shift register memory and inserting the value of the added 
predetermined bits into a^i- 

16. The method of claim 15, wherein aois added with a^to form a next a^, . 

10 17. The method of claim 12, finther comprising the step of cyclically 

shifting the second shift register memory. 

18. The method of claim 17, wherein the step of cycUcaUy shifting the 
second shift register memory comprises the stq>s of adding predetermined bits of the 

1 5 second shift register memory based on the second generator polynomial of the second m- 
sequence, right shifting the second shift register memory and inserting the value of the 
added predetermined bits into h^^. 

19. The m^od of claim 18, wherein bg is added with b,, by, andb,o_to 
20 form a next b^.,. 

20. The method of claim 11, finther comprising the step of delaying the 
each of the secondary scrambling codes to produce Q-channel components of the 
secondary scrambling codes, wherein the undelayed secondary scrambling codes are I- 

25 channel coirq^onents of the secondary scrambhng codes. 

21. An qyparatus for generating a primary scrambling code and secondary 
scrambling codes associated with the primary scrambling code for a mobile 
telecommunication system, the apparatus comprisiag: 

30 a first shift register memory for generatmg a first m-sequence, said first 

shift register memory having a phmlity of registers with values a^ (i = 0 to c-1 
where c = the total number of registas); 

- a secorxd shift register memory for geneniting a second m-sequence,^^ 
second shift register memory having a phnrahty of registers with vahies bj (i = 0 to 
35 c-1 ^ere c = the total number of registers); 

a primary adder for adding the first m-sequence with the second m-sequence to 
generate the primary scrambling code; 

a plurality of masking sections for masking aj (i = 0 to c-1) to produce 
secondary sequences; and 
40 a phnaHty of secondary addere for adding the secondary sequences with the 
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second m-sequence to produce the secondary scrambling codes, 

wherein each of the masking sections cycUcally shifts the first m-sequence by 
using a mask. 

22. The apparatus of claim 21, wherein the first and second m-sequences 
are generated based on a first generator polynomial and a second generator polynomial, 
respectively. 

23. The apparatus of claim 21, wherein the mask in each of the masking 
sections is expressed by the foDowing equation: ^ {k^i x a-) . 

24. The £q>paratus of claim 22, finther comprising a first register adder for 
adding the bits of the first shift register memory, wherein the first shift register memory 
is cyclically shifted by adding predetermined bits of the first shift register memory in the 
first register adder based on the first goierator polynomial of the first m-sequence, right 
shifting the first shift register memory and inserting the output of the first register adder 
into a^,. 

25. The apparatus of claim 24, wherein a^ is added with a^ to form a next a^. 

26- The qiparatus of claim 24, fiirther comprising a second register adder 
for adding the bits of the second shift register memory, wherein the second shift register 
rnemory is cyclically shifted by adding predetermined bits of the second shift register 
memory in the second register adder based on the second generator polynomial of the 
second m-sequence, right shifting the second shift register memory and inserting the 
ou^ut of the second re^s/tex zddcr into a^^,. 

27. The apparatus of claim 26, wherein bo is added with b,, b7 and b,o to 
form a next b^,. 

28. The s^aratus of claim 21, fiirther comprising a pluraUty of delay 
blocks for delaying the ou^uts of the primary adder and the secondary adders for 
pre£icmg Q cfaimel"c»rr4)6neits priiriary krambling code and the secondary' 
scrambling codes. 

29. An a^jparatus for generating a primary scrambling code and a 
secondary scrambting code associated with the primary scrambling code for a mobile 
telecommimication system, the apparatus compnsmg: 

a first shift roister mraiory for generating a first m-sequence, said first 
shift register manory having a phirality of registers with values a; (i = 0 to c-1 
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where c = the total number of registers); 

a second shift register memory for generating a second m-sequence, said 
second diift register memory having a plurality of registers with values bj (i = 0 to 
c-1 where c = the total nimiber of registers); 

a primary adder for adding the first m-sequence with the second m-sequence to 
generate the primary scrambling code; and 

a masking section for masking a^ (i = 0 to c-1) to produce a secondary sequence; 

a secondary adder for adding the secondary sequence with the second m- 
sequence to produce the secondary scrambling code, 

wherein the masking section cycUcally shifts the first m-sequence by using a 

mask. 

30. The apparatus of claim 29, finlher comprising a plundity of delay ^ 
blocks for delaying the ou^uts of the primary adder and the secondary adder for 
producing Q channel components of the primary scrambling code and the secondary 
scrambling code. 
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